一 介绍

计算机系统分为:计算机硬件,操作系统,应用程序三部分。
我们用python或其他语言编写的应用程序若想要把数据永久保存下来,必须要保存于硬盘中,这就涉及到应用程序要操作硬件,众所周知,应用程序是无法直接操作硬件的,这就用到了操作系统。操作系统把复杂的硬件操作封装成简单的接口给用户/应用程序使用,其中文件就是操作系统提供给应用程序来操作硬盘虚拟概念,用户或应用程序通过操作文件,可以将自己的数据永久保存下来。
文件路径:
相对路径:Linux和os x中用/,Windows中用,该位置相对于当前程序所在目录
绝对路径:同上,读取系统任何地方文件,由于在Python中是转义符建议路径前加上r
有了文件的概念,我们无需再去考虑操作硬盘的细节,只需要关注操作文件的流程:
1、打开文件,得到文件句柄并赋值给一个变量

f=open('a.txt','r',encoding='utf-8')  # 默认打开模式就为r

2、通过句柄对文件进行操作

data=f.read()

3、关闭文件

f.close()  #操作过程存储在内存与缓存中,在程序结束或者close之后写入磁盘

上下文与回收
打开一个文件包含两部分资源:操作系统级打开的文件+应用程序的变量。在操作完毕一个文件时,必须把与该文件的这两部分资源一个不落地回收,回收方法为:
1、f.close() #回收操作系统级打开的文件
2、del f #回收应用程序级的变量
注意:其中del f一定要发生在f.close()之后,否则就会导致操作系统打开的文件还没有关闭,白白占用资源,而python自动的垃圾回收机制决定了我们无需考虑del f,这就要求我们,在操作完毕文件后,一定要记住f.close()。如果程序存在bug,导致close()未执行,文件不会关闭。

whit管理上下文:

with open('a.txt','w') as f:
    pass 
with open('a.txt','r') as read_f,open('b.txt','w') as write_f:
    data=read_f.read()
    write_f.write(data)

注意:当with代码块执行完毕时,内部会自动关闭并释放文件资源。open()返回的文件对象只在with内可用,如果要在外部访问需将with内创建列表,再从外部使用
文件编码

f=open(...)是由操作系统打开文件,那么如果我们没有为open指定编码,操作系统会用自己的默认编码去打开文件,在windows下是gbk,在linux下是utf-8。
f=open('a.txt','r',encoding='utf-8')

二 文件操作

操作文件时,一般需要经历如下步骤:
1、打开文件
文件句柄 = file('文件路径', '模式')
注:python中打开文件有两种方式,即:open(...) 和 file(...) ,本质上前者在内部会调用后者来进行文件操作,推荐使用 open。

打开文件的模式有:

打开文件的模式有(默认为文本模式):

  • r :只读模式【默认模式,文件必须存在,不存在则抛出异常】
  • w :只写模式【不可读;不存在则创建;存在则清空原内容写入新内容】
  • a :追加写模式【不可读;不存在则创建;存在则在光标位置追加内容】

非文本文件,我们只能使用b模式,"b"表示以字节的方式操作(无需考虑文本、图片、视频的格式):

  • rb :只读模式
  • wb :修改并读取
  • ab :追加字节

注意:以b方式打开时,读取到的内容是字节类型,写入时也需要提供字节类型,不能指定编码

其他模式

  • "+" :表示可以同时读写某个文件
  • r+ :读写【可读,可写】#追加写,文件光标位置处,默认在开始位置
  • w+ :写读【可读,可写】#清除覆盖原有内容,默认光标位置在开始,用seek读
  • a+ :写读【可读,可写】#不清空在最后位置追加,用seek读。
  • x :只写模式【不可读】#不存在则创建,存在则报错
  • x+ :写读【可读,可写】
  • "U" :表示在读取时,将 r n rn自动转换成 n (与r或r+模式同使用)

       rU     r+U

操作文件方法

import sys #系统函数

print(f.tell()) #返回光标位置

f.read() #从光标初读取所有内容,并移动到末尾返回空字符串即空行

f.read(3) #文本模式读三个字符,b模式读取3个字节

f.readline() #读取一行内容,光标移动到第二行首部

f.readlines() #读取所有行内容,存放于列表中,在循环迭代时获取

f.xreadlines() #可用于逐行读取文件,非全部

f.readinto() #读取到缓冲区,不要用,将被遗弃

f.seek(0) #指定文件中指针位置,0代表开始位置,不同于read。

f.seek(3,2) #从第三个字节开始打印,seek应用,如断点续传

f.tell() #获取当前指针位置

f.truncate() #截断文件,保留指定之前的数据。
注意:文件的打开方式必须可写,不能用w或w+等方式打开,因为那样直接清空文件了,所以truncate要在r+或a或a+等模式下测试效果.

f.write(“xx”) #文本模式写入缓存,b模式需要加.encode('utf-8')

f.flush() #立刻从内存刷到磁盘中及屏幕上

f.time.sleep(100)#100秒后写入磁盘

f.close() #写入磁盘或程序结束后写入磁盘

f.stdout.write(“xx”) #向屏幕输出内容,代表文件写、输出,先进了缓存

f.write('1111n222n') #针对文本模式的写,需要自己写换行符

f.write('1111n222n'.encode('utf-8')) #针对b模式的写,需要自己写换行符

f.writelines(['333n','444n']) #文件模式,字符串写入文件

f.writelines([bytes('333n',encoding='utf8'),'444n'.encode('utf-8')]) #b模式

f.readable() #文件是否可读

f.writable() #文件是否可写

f.close() #关闭文件

f.closed #文件是否关闭

f.encoding #如果文件打开模式为b,否则没有该属性

f.fileno() #文件描述符

f.isatty() #判断文件是否是同意tty设备

f.next() #获取下一行数据,不存在时报错

练习:

打印一首诗
f 读取一行,执行完后被回收,优化内存

利用b模式,编写一个cp工具,要求如下:

  1. 既可以拷贝文本又可以拷贝视频,图片等文件
  2. 用户一旦参数错误,打印命令的正确使用方法,如usage:cp source_file target_file

请输入代码

pivpi
5 声望0 粉丝